import axios from "axios";
import "element-plus/es/components/message/style/css";
import { ElMessage } from "element-plus";
import { useCategroyStore } from "@/stores/categroy.js";
import { useRouter } from "vue-router";
const router = useRouter();

const instance = axios.create({
  baseURL: "http://pcapi-xiaotuxian-front-devtest.itheima.net",
  timeout: 4000,
});
// 添加请求拦截器
instance.interceptors.request.use(
  function (config) {
    // 在发送请求之前做些什么
    const getLoginStore = useCategroyStore();
    const token = getLoginStore.loginList.token;
    if (token) {
      config.headers.Authorization = `Bearer ${token}`;
    }
    return config;
  },
  function (error) {
    // 对请求错误做些什么
    return Promise.reject(error);
  }
);

// 添加响应拦截器
instance.interceptors.response.use(
  function (response) {
    // 2xx 范围内的状态码都会触发该函数。
    // 对响应数据做点什么
    return response;
  },
  function (error) {
    const getLoginStore = useCategroyStore();
    // 超出 2xx 范围的状态码都会触发该函数。
    // 对响应错误做点什么
    ElMessage({
      type: warning,
      message: error.response.data.message,
    });
    if (error.response.status === 401) {
      getLoginStore.clearlogin();
      router.push("login");
    }
    return Promise.reject(error);
  }
);
export default instance;
